草庐IT

SQL语句 -非空约束 - 唯一约束 - 主键约束 - 默认约束 -外键约束

全部标签

ruby - 强制使用特定的 gem 版本作为默认版本?

假设我安装了三个gem:package-0.4.0、package-0.5.0和package-0.5.0-jbfink(我构建了-jbfink一个,因为我对0.5做了非常小的改动.0的来源,并希望将其与官方版本区分开来)。是否有gem(或其他命令)将其设为默认值?现在我已经安装了所有三个,但我的shell正在从package-0.5.0中获取可执行文件,我宁愿它默认为0.5.0-jbfink。将0.5.0-jbfink命名为0.5.1解决了这个问题,但我不想这样做,因为我不想与正式发布的0.5.1出现冲突。 最佳答案 转到conf

ruby-on-rails - 如何更改 Rails 3 路由中的默认参数名称?

在我的Rails3项目中,我有一个这样的路由列表:resources:projectsdoresources:studiesendresources:sticky_notesresources:study_templates...目前默认情况下,可以使用params[:id]调用这些路由的URL中的id,但我希望能够使用params[:sticky_note_id]、params[:study_template_id]、params[:study_id]调用它们],等等。有没有办法为这些项目的ID指定参数名称?我是否必须在没有“资源”的情况下手动写出每条路线?谢谢!编辑:这是我正在尝试

ruby-on-rails - Ruby 和 SQL 中的重复业务逻辑

我有一个PORO(普通旧Ruby对象)来处理一些业务逻辑。它接收一个ActiveRecord对象并对其进行分类。为了简单起见,以下面为例:classClassificatorSTATES={1=>"Positive",2=>"Neutral",3=>"Negative"}definitializer(item)@item=itemenddefnameSTATES.fetch(state_id)endprivatedefstate_idreturn1if@item.value>0return2if@item.value==0return3if@item.value但是,我还想根据这些st

ruby-on-rails - 自定义 Rails 的默认 Resourceful Route 路径

长话短说我想更改Rails资源路由的默认行为,移动所有资源的create路径,使其成为/resources/new的POST而不是比/resources。设置让我们假设一个像这样指定的足智多谋的路线:#routes.rbresources:events实际生成的路由是:$rakeroutesPrefixVerbURIPatternController#ActioneventsGET/events(.:format)events#indexPOST/events(.:format)events#createnew_eventGET/events/new(.:format)events#n

sql - ActiveRecord 的意外行为包括

我正在使用ARincludes在对象User和Building之间执行LEFTOUTERJOIN的方法,其中User可能有也可能没有Building关联:users=User.includes(:building).references(:buildings)因为我正在使用references,任何关联的Building对象都将被预先加载。我的期望是我随后能够遍历用户列表,并检查用户是否有与其关联的建筑物而不会触发额外的查询,但实际上每当我尝试访问建筑物属性时我都会看到对于没有建筑物的用户,AR会进行另一个SQL调用以尝试检索该建筑物(尽管在后续尝试中它只会返回nil)。这些查询显然是

sql - 如何查询具有 3 个标签的事件?

我有以下模型:activity.rbtag.rbtagging.rb标签是事件和标签的连接模型。我想搜索具有2个或更多标签的事件。我如何在Rails中执行此操作?例如:我有tag1=Christmas,tag2=Florida,tag3=John如果存在,我想找到tag1、tag2和tag3存在的Activity。[编辑]我最终做了什么:tags=[tag1,tag2,tag3]activities=[]tags.eachdo|tag|activities如果任何组值的大小等于tags.size,则该事件包含所有标签。 最佳答案 如

ruby-on-rails - 使用 STI 为 rails 中的子模型指定唯一属性

我计划将STIinRails与以下模型一起使用:classPromoEvent和Discount在属性方面仅存在一些差异,因此我认为STI是一个不错的选择。我不确定如何确保,例如,仅Event具有额外的image_filename属性。我知道它会在promos表中,并且它必须是NULL-able以防我插入Discount行。如何确保Discount对象对image_filename属性一无所知(即未在Discount.column_names中列出>和/或无法设置它)Event知道它吗? 最佳答案 我认为这个概念是不同的,而你的Pr

ruby - Sinatra/Ruby 默认一个参数

有没有办法在Sinatra中设置默认参数?我目前正在查看是否将'start'作为参数传递,但这似乎有点老套。如果我可以告诉Sinatra在未指定的情况下默认某些参数,那就太好了。get'/comments/?'do#wanttosetuppagestuff,defaulttofirstpageifnotspecifiedparams[:start]=0if!params[:start]end有什么想法吗? 最佳答案 确实可以这样使用||=,但是在检索它们之后设置参数是一件非常奇怪的事情。您更有可能通过参数设置变量。所以不是这个:pa

ruby - 为什么 Date 类的新实例的默认年份等于 -4712?

运行:require'date'y=Date.newputs"defaultyearis#{y.year}"输出:defaultyearis-4712Date对象的年份默认为-4712是否有任何特殊原因?我认为也许有技术(或传统)原因。我用谷歌搜索并在Ruby文档(2.2.3)中查找了它,但我找不到关于为什么的答案。 最佳答案 公元前4713年1月1日是Julianday的开始,来自维基:TheJulianDayNumber(JDN)istheintegerassignedtoawholesolardayintheJulianday

ruby-on-rails - 如何针对组合字段的唯一性对这种复杂的验证进行建模

link有两个组件:componenta_id和componentb_id。为此,在Link模型文件中我有:belongs_to:componenta,class_name:"Component"belongs_to:componentb,class_name:"Component"validates:componenta_id,presence:truevalidates:componentb_id,presence:truevalidates:componenta_id,uniqueness:{scope::componentb_id}validates:componentb_id